- name: create slave
  become: true
  become_user: "{{ slave_user }}"
  command: creates={{ slave_dir }} buildslave create-slave {{ slave_dir }} {{ buildmaster }} buildslave passwd
  when: deployment_type in ['local', 'qa-stg']

- name: generate slave config
  become: true
  become_user: "{{ slave_user }}"
  template: src=buildbot.tac.j2 dest={{ slave_dir }}/buildbot.tac mode=0600 owner={{ slave_user }} group={{ slave_user }}
  when: deployment_type in ['local', 'qa-stg']

- name: generate slave info
  become: true
  become_user: "{{ slave_user }}"
  template: src={{ item }}.j2 dest={{ slave_dir }}/info/{{ item }} mode=0644 owner={{ slave_user }} group={{ slave_user }}
  with_items:
    - admin
    - host
  when: deployment_type in ['local', 'qa-stg']

- name: create slave ssh directory
  when: buildslave_public_sshkey_file is defined and (deployment_type in ['local', 'qa-stg'])
  file: path={{ slave_home }}/.ssh owner={{ slave_user }} group={{ slave_user }} mode=0700 state=directory
  #when: buildslave_public_sshkey_file is defined and (deployment_type in ['prod', 'stg', 'local', 'qa-stg'])

- name: install slave ssh private key
  when: buildslave_public_sshkey_file is defined and (deployment_type in ['local', 'qa-stg'])
  copy: src={{ private }}/files/taskotron/{{ buildslave_private_sshkey_file }} dest={{ slave_home }}/.ssh/id_rsa owner={{ slave_user }} group={{ slave_user }} mode=0600

- name: install slave ssh public key
  when: buildslave_public_sshkey_file is defined and (deployment_type in ['local', 'qa-stg'])
  copy: src={{ private }}/files/taskotron/{{ buildslave_public_sshkey_file }} dest={{ slave_home }}/.ssh/id_rsa.pub owner={{ slave_user }} group={{ slave_user }} mode=0644

- name: make sure master is in known_hosts
  when: buildslave_public_sshkey_file is defined and (deployment_type in ['local', 'qa-stg'])
  lineinfile: dest=/home/{{ slave_user }}/.ssh/known_hosts regexp='{{ buildmaster }}' line='{{ buildmaster }} {{ buildmaster_pubkey }}' create=yes owner={{ slave_user }} group={{ slave_user }}

- name: generate buildslave service file
  template: src=buildslave.service.j2 dest=/lib/systemd/system/buildslave.service owner=root group=root mode=0744
  when: deployment_type in ['local', 'qa-stg']
  register: buildslave_service

- name: reload systemd
  command: systemctl daemon-reload
  when: deployment_type in ['local', 'qa-stg'] and buildslave_service.changed

- name: start and enable buildslave service
  service: name=buildslave enabled=yes state={{ (buildslave_service.changed) | ternary('restarted','started') }}
  when: deployment_type in ['local', 'qa-stg']

- name: create slave
  become: true
  become_user: '{{ item.user }}'
  command: creates={{ item.dir }} buildslave create-slave {{ item.dir }} {{ buildmaster }} buildslave passwd
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: deployment_type in ['dev', 'stg', 'prod']

- name: generate slave config
  become: true
  become_user: '{{ item.user }}'
  template: src=buildbot.tac.j2 dest={{ item.dir }}/buildbot.tac mode=0600 owner={{ item.user }} group={{ slaves_group }}
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: deployment_type in ['dev', 'stg', 'prod']

- name: generate slave admin info
  become: true
  become_user: '{{ item.user }}'
  template: src=admin.j2 dest={{ item.dir }}/info/admin mode=0644 owner={{ item.user }} group={{ slaves_group }}
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: deployment_type in ['dev', 'stg', 'prod']

- name: generate slave host info
  become: true
  become_user: '{{ item.user }}'
  template: src=host.j2 dest={{ item.dir }}/info/host mode=0644 owner={{ item.user }} group={{ slaves_group }}
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: deployment_type in ['dev', 'stg', 'prod']

- name: create slave ssh directory
  file: path={{ item.home }}/.ssh owner={{ item.user }} group={{ slaves_group }} mode=0700 state=directory
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: buildslave_public_sshkey_file is defined and deployment_type in ['dev', 'stg', 'prod']

- name: install slave ssh private key
  copy: src={{ private }}/files/taskotron/{{ buildslave_private_sshkey_file }} dest={{ item.home }}/.ssh/id_rsa owner={{ item.user }} group={{ slaves_group }} mode=0600
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: buildslave_private_sshkey_file is defined and deployment_type in ['dev', 'stg', 'prod']

- name: install slave ssh public key
  copy: src={{ private }}/files/taskotron/{{ buildslave_public_sshkey_file }} dest={{ item.home }}/.ssh/id_rsa.pub owner={{ item.user }} group={{ slaves_group }} mode=0644
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: buildslave_public_sshkey_file is defined and deployment_type in ['dev', 'stg', 'prod']

- name: make sure master is in known_hosts
  lineinfile: dest={{ item.home }}/.ssh/known_hosts regexp='{{ buildmaster }}' line='{{ buildmaster }} {{ buildmaster_pubkey }}' create=yes owner={{ item.user }} group={{ slaves_group }}
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: buildslave_public_sshkey_file is defined and deployment_type in ['dev', 'stg', 'prod']

- name: ensure correct fcontext for buildslave dir
  file: path={{ item.home }}/slave setype=var_lib_t owner={{ item.user }} group={{ slaves_group }} mode=0700 state=directory
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: deployment_type in ['dev', 'stg', 'prod']

- name: generate buildslave service file
  template: src=buildslave@.service.j2 dest=/lib/systemd/system/buildslave@.service owner=root group=root mode=0644
  when: deployment_type in ['dev', 'stg', 'prod']
  register: buildslave_service

- name: reload systemd
  command: systemctl daemon-reload
  when: deployment_type in ['dev', 'stg', 'prod'] and buildslave_service.changed

- name: start and enable buildslave services
  service: name=buildslave@{{ item.user }} enabled=yes state={{ (buildslave_service.changed) | ternary('restarted','started') }}
  with_items:
    - '{{ slaves|default([dict(user="", home="", dir="")]) }}'
  when: deployment_type in ['dev', 'stg', 'prod']
